## BEST AVAILABLE COPY

#### PATENT ABSTRACTS OF JAPAN

(11)Publication number:

2002-149212

(43)Date of publication of application: 24.05.2002

(51)Int.CI.

G05B 19/05 GO5B 9/03 G06F 11/20 G06F 13/00 G06F 13/38 G06F 13/42

(21)Application number: 2000-345765

(71)Applicant:

**FUJI ELECTRIC CO LTD** 

(22)Date of filing:

13.11.2000

(72)Inventor:

YUGAWA MAKIKO

SUZUKI MOTOHARU

#### (54) REDUNDANT PROGRAMMABLE CONTROLLER FOR EQUALIZING CONTROL DATA AND EQUALIZATION METHOD **毎後化データの収集・送信のタイスングを示す性**

PROBLEM TO BE SOLVED: To provide a programmable controller which has a mechanism for achieving equalization processing without disordering the fixed periodicity of a fixed-period task.

SOLUTION: A task which performs equalization processing is divided into processing for gathering equalization data and processing for transmitting the gathered equalization data. The equalization data are transmitted to a standby- side CPU while divided into multiple equalization files. When the timing of the start of the fixed-period task is reached during the equalization processing, the fixed-period task is interposed. Frame No.s and serial No.s are put in the equated files to accurately perform the transmission and reception. An in- operation side CPU and a standby side CPU has the same transfer table and transfer systems for gathering and distribution are changed according to the arrangement of the data to be equalized.



#### **LEGAL STATUS**

[Date of request for examination]

14.09.2005

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

Copyright (C); 1998,2003 Japan Patent Office

#### (19)日本国特許庁 (JP)

# (12) 公開特許公報(A)

(11)特許出顧公開番号 特開2002-149212 (P2002-149212A)

(43)公開日 平成14年5月24日(2002.5.24)

|              |       |                              |               |                    |     | (40) Др | 1 H      | TW144-071 | 71 (E00E. 0. E1) |
|--------------|-------|------------------------------|---------------|--------------------|-----|---------|----------|-----------|------------------|
| (51) Int.Cl. |       | 識別記号                         |               | FI                 |     |         |          | ī         | -7]-1*(参考)       |
| G 0 5 B      | 19/05 |                              |               | G 0                | 5 B | 9/03    |          |           | 5 B 0 3 4        |
|              | 9/03  |                              |               | G 0                | 6 F | 11/20   |          | 310C      | 5 B O 7 7        |
| G06F         | 11/20 | 310                          |               |                    |     | 13/00   |          | 301P      | 5 B 0 8 3        |
|              | 13/00 | 301                          |               |                    |     | 13/38   |          | 340A      | 5 H 2 O 9        |
|              | 13/38 | 3 4 0                        |               | 13/42              |     |         |          | 350A      | 5 H 2 2 0        |
|              |       |                              | 審查請求          | 未請求                | 請求  | 項の数13   | OL       | (全 18 頁)  | 最終頁に続く           |
| (21)出願番号     |       | 特顧2000-345765( P2000-345765) |               | (71)出願人 000005234  |     |         |          |           |                  |
|              |       |                              |               |                    | •   | 富士電     | 農株式      | 会社        |                  |
| (22)出顧日      |       | 平成12年11月13日(2000             |               |                    | 神奈川 | 界川崎     | 市川崎区田辺   | 新田1番1号    |                  |
|              |       |                              | (72)発明者 湯川 真規 |                    |     |         | <u>.</u> |           |                  |
|              |       |                              |               | 神奈川県川崎市川崎区田辺新田1番1号 |     |         |          |           |                  |
|              |       |                              |               | 富士電機株式会社内          |     |         |          |           |                  |
|              |       |                              |               | (72)               | 発明者 | 6 鈴木    | 元治       |           |                  |
|              |       |                              |               | 神奈川県川崎市川崎区田辺新田1番1号 |     |         |          |           |                  |
|              |       |                              |               |                    |     | 當士電     | 機株式      | 会社内       |                  |
|              |       |                              |               | (74)               | 代理人 | 100074  | 099      |           |                  |
|              |       |                              |               |                    |     | 弁理士     | 大省       | 義之        |                  |
|              |       |                              |               |                    |     |         |          |           |                  |
|              |       |                              |               |                    |     |         |          |           | 最終頁に続く           |
|              |       |                              |               |                    |     |         |          |           |                  |

### (54) 【発明の名称】 制御データを等値化する冗長化プログラマブルコントローラ及び等値化方法。

#### (57)【要約】

【課題】 本発明は、定周期タスクの定周期性を崩さずに、等値化処理を実現する仕組を持つプログラマブルコントローラを提供することを課題とする。

【解決手段】 等値化処理を行うタスクを、等値化データを収集する処理及び収集した等値化データを送信する処理に分ける。又等値化データを複数の等値化ファイルに分けて待機側CPUに送信する。等値化処理中に定周期タスクを開始するタイミングとなったら、間に定周期タスクを割込ませる。等値化ファイルにフレームNo. とシリアルNo. を格納し、送受信を正確に行う。稼動側CPUと待機側CPUとで同じ転送テーブルを持ち、また等値化するデータの配置によって、収集・分配する為の転送方式を変える。



#### 【特許請求の範囲】

【請求項1】 2重化して冗長性を持たせた1乃至複数 組のCPUを持ち、稼動側CPUと待機側CPUとの間 でデータの等値化を行うプログラマブルコントローラに

前記稼動側CPUは、等値化対象としているデータを収 集する等値化データ収集手段と、

前記等値化データ収集手段が収集したデータを等値化フ レームによって前記待機側CPUに送信する等値化デー タ送信手段と、

前記等値化データ収集手段による収集処理中に定周期タ スクを開始するタイミングになった時、該収集処理完了 後前記等値化データ送信手段によるデータの送信開始前 に該定周期タスクを実行する定周期タスク実行手段とを 備えることを特徴とするプログラマブルコントローラ。

【請求項2】 前記等値化データ送信手段は、前記等値 化データ収集手段が収集したデータを複数の等値化フレ ームに分けて送信することを特徴とする請求項1に記載 のプログラマブルコントローラ。

マブルコントローラの構成に基づいて前記等値化フレー ムの大きさを調整することを特徴とする請求項1又は2 に記載のプログラマブルコントローラ。

【請求項4】 前記等値化データ送信手段は、前記等値 化フレームに該等値化フレーム内のデータの整合性をチ ェックする情報を格納し、前記待機側CPUは、受信し た等値化フレームの前記整合性をチェックする情報を調 べて、整合性が確認された時のみ等値化データを分配す る等値化データ分配手段を備えることを特徴とする請求 項2又は3に記載のプログラマブルコントローラ。

【請求項5】 前記整合性をチェックする情報は、どの 収集処理による等値化データかを表すフレームNo. と複 数に分割したうちの何番目の等値化フレームかを示すシ リアルNo. であること特徴とするを請求項4に記載のプ ログラマブルコントローラ。

【請求項6】 前記待機側CPUは、前記等値化データ 分配手段が分配している間に受信した等値化フレーム内 のデータを該分配しているデータの格納領域とは異なる ダミー領域に格納するフレーム受信手段を更に備えると コントローラ。

【請求項7】 等値化データ送信手段は、前記等値化デ ータ収集手段が収集したデータを全て送信後、該前記等 値化データ収集手段が次の収集処理を完了するまでの 間、ダミーフレームを送信することを特徴とする請求項 1乃至6のいずれか1に記載のプログラマブルコントロ

【請求項8】 前記等値化フレーム送信手段は、等値化 フレームの送信中に送信異常が発生した時、残りの等値 化フレームの送信を止めて、前記等値化データ収集手段 50 ロセスデータの入出力を行う 1 / O モジュール及び不図

に次の収集処理の開始を指示することを特徴とする請求 項2乃至7のいずれか1に記載のプログラマブルコント ローラ。

【請求項9】 前記等値化データ分配手段は、前記等値 化データ収集手段がデータの収集に用いた転送テーブル と同じ転送テーブルを用いてデータの分配を行うことを 特徴とする請求項4乃至8のいずれかに記載のプログラ マブルコントローラ。

【請求項10】 前記等値化データ収集手段及び等値化 10 データ分配手段は、等値化対象となるデータの配置に基 づいて、データの収集・分配時のデータ転送に最適な転 送方式の選択することを特徴とする請求項4乃至9のい ずれかに記載のプログラマブルコントローラ。

【請求項11】 前記等値化データ収集手段は、デフォ ルトタスクの終了のタイミングに基づいて前記収集処理 の開始のタイミングを決定することを特徴とする請求項 1乃至10のいずれかに記載のプログラマブルコントロ

【請求項12】 前記等値化データ収集手段は、等値化 【請求項3】 前記等値化データ送信手段は、プログラ 20 データ送信手段が等値化フレームを送信中に前記定周期 タスクを開始するタイミングになった時、その等値化フ レームの送信処理完了後、次の等値化フレームの送信開 始前に該定周期タスクを実行することを特徴とする請求 項1乃至11に記載のプログラマブルコントローラ。

> 【請求項13】 2重化して冗長性を持たせた1乃至複 数組のCPUを持つプログラマブルコントローラにおけ る、稼動側CPUと待機側CPUとの間でのデータの等 値化方法であって、

前記稼動側CPUは、

30 等値化対象としているデータを収集し、

前記収集したデータを格納した等値化フレームを前記待 機側CPUに送信し、

前記収集中に定周期タスクを開始するタイミングになっ た時、該収集が完了した後、前記等値化フレームの送信 前に該定周期タスクを実行することを特徴とする等値化 方法。

【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、産業用制御装置で とを特徴とする請求項4又は5に記載のプログラマブル 40 あるプログラマブルコントローラにおける入出力制御方 式に関し、更に詳しくは制御データの等値化に関する。 [0002]

> 【従来の技術】現在、プラント、工場などでは、機械や 装置のシーケンス制御に多くのプログラマブルコントロ ーラ(以下PCという)を用い、FA(ファクトリーオ ートメーション)化を実現している。

> 【0003】図16に一般的なマルチCPU構成のPC の例を示す。1つのPCは、プログラムの実行やデータ の演算処理等を行うCPUモジュールや、制御機器とプ

示の通信モジュールが複数接続されて構成されている。 これら各モジュールは、システムパス101を介して互 いにデータのやりと合りを行い、接続機器の制御処理を 行う。

3

【0004】PCが複数のCPUモジュール102を備 えるマルチCPU構成の場合、各CPUモジュール10 2はそれぞれ個別に動作する。よって従来から行われて いる入出力制御方式では、CPUモジュール102によ る 1 / 〇 モジュール 1 0 3 などからのプロセスデータの 取込みや、 I / Oモジュールなどへのプロセスデータの 10 出力を行う入出力処理は、各CPUモジュール102間 で非同期に行われる。

【0005】このため各CPUモジュール102間では 同期したデータを使用した処理は行っていない。さらに I/Oモジュール103へのプロセスデータの出力につ いても、各CPUモジュール102は独自のタイミング で出力しているので、「/〇モジュール103へのプロ セスデータの出力は各CPUモジュール102間で同期 していない。

【0006】各1/0モジュール103は、接続機器か 20 周期性が崩される。 らのプロセスデータの出力をリアルタイムで行い、また CPUモジュール102からのデータをリアルタイムで 必要とする。よって、複数のCPUモジュール102が 連携して処理を行う場合には、CPUモジュール102 間やタスク間で同期が行われていないと異なるデータを 同じデータと認識して処理してしまうなどの問題が生じ る場合がある。

【0007】上記問題点を考慮し、CPUモジュール間 やマルチタスク処理時のタスク間で同期してデータのや り取りを行うことを可能としたものとして、本出願と同 30 一出願人による特開平11-338523号「プログラ マブルコントローラにおける入出力制御方式」(以下先 願の方式という) がある。

【0008】 先願の方式では、各CPUモジュール10 2内で、システムバス101の転送速度と同じ速度で実 行プロセッサにタクト割込みを一定周期で発生させ、各 CPUモジュール102内の実行プロセッサが、このタ **クト割込みの発生周期(タクト周期)に同期させて I /** 〇モジュール103に対する入出力処理を行うことによ ってCPUモジュール102間の同期処理を実現してい 40 つプログラマブルコントローラ及び等値化方法を提供す る。

#### [0009]

【発明の解決しようとする課題】ところで、システムの 信頼性を向上させるためCPUモジュールをデュプレッ クス構成にして冗長性を持たせる場合がある。例えば、 図16の構成において、CPUモジュール102-1. 102-3を稼動側とし、CPUモジュール102-2. 102-4をその待機側とする。そして稼動側のC PUモジュール102-1や101-3にエラーが生じ

01-4が稼動状態に切り替ってエラーが生じたCPU モジュール102の代わりに処理を務める。

【0010】との様なデュプレックス構成の場合、切り 替り時に処理を引き継げるように、稼動側CPUモジュ ール102-1、102-3から待機側のCPUモジュ ール102-2,102-4に対して制御データの等値 化が行われる。先願の方式の様にPCが特定周期(タク ト周期)によりCPUモジュール間やIOモジュールな どとの間で制御データの受け渡しを行い、タクト周期に 同期してタスクを実行する構成においては、上記データ の等値化の処理を行う場合、以下の問題点がある。

1)図17は等値化処理のタイミングを示す図である。 同図に示すように、先願の方式で等値化処理を行った場 合、デフォルトタスクの終了(タスクエンド)のタイミ ングでシステムの等値化処理を行うことになる。この等 値化処理を行っている間、定周期タスクは処理を行え ず、CPUが空くのを待つことになる。よって等値化処 理にCPUが取られる時間が長いと、定周期タスクはそ の分CPUが解放されるのを待つこととなり、処理の定

2) 1フレーム内に格納されている等値化処理の為のデ ータが1タクト周期内に処理しきれない大きさのもので あった場合、タクト周期が伸びてしまう。従ってタクト 周期に同期して実行されている定周期タスクの周期も大 きくなってしまう。

3) 等値化処理の為のデータを格納しているフレーム内 に、その等値化データがどのタイミングで収集されたデ ータなのかを示す情報が無いので収集したデータの同期 保証が出来ない。

4)全フレームのデータ収集の同期を保証しなければな らないのに、送り出すデータを収集している間に、通常 のフレームを送信してしまうと、不定なデータが送られ てしまい、データの同期保証ができない。

5) 稼動側CPU用と待機側CPU用とで、等値化デー タの収集、及びアプリケーションデータ領域への分配に それぞれ転送テーブルを必要とするが、この転送テーブ ルを用意するためにメモリ資源を多く消費してしまう。 【0011】上記問題点を鑑み、本発明は定周期タスク の定周期性を崩さずに、等値化処理を実現する仕組を持

【0012】また不定な等値化データを待機側に送信し たり、無駄なフレームを送信しないようにする仕組を持 つプログラマブルコントローラを提供することを課題と

ることを課題とする。

【0013】更に待機側では、受信データで分配処理が 完了する前のデータを破壊したり、不定なデータをアプ リケーションデータ領域に分配しない仕組を持つプログ ラマブルコントローラを提供することを課題とする。

ると対応する待機側のCPUモジュール102-2や1 50 【0014】また資源を有効利用し、更に等値化データ

5

の収集、分配のパフォーマンスを向上させる仕組を持つ プログラマブルコントローラを提供することを課題とす る。更に高速に制御データの等値化処理を行うことが出 来るプログラマブルコントローラを提供することを課題 とする。

#### [0015]

【0016】等値化データ収集手段は、上記稼動側CPUは、等値化対象としているデータを収集する。等値化データ送信手段は、上記等値化データ収集手段が収集したデータを等値化フレームによって上記待機側CPUに送信する。

【0017】定周期タスク実行手段は、上記上記等値化 データ収集手段による収集処理中に定周期タスクを開始 するタイミングになった時、該収集処理完了後上記等値 20 化データ送信手段によるデータの送信開始前に該定周期 タスクを実行する。

【0018】との構成により、定周期タスクは等値化処理が完了するのを待たずに実行することが出来る。また上記等値化データ送信手段は、上記等値化データ収集手段が収集したデータを複数の等値化フレームに分けて送信する構成とすることが出来る。この構成により等値化データの量が多くてもタクト周期の周期性を壊すことが無い。またこの時各等値化フレームに等値化フレーム内のデータの整合性をチェックする情報を格納し、これを待機側CPUで受信した等値化フレームの上記整合性をチェックする情報を調べて、整合性が確認された時のみ等値化データを分配する構成にすることにより、整合性が取れた等値化データのみが等値化される。

【0019】更に、上記等値化データ収集手段及び等値 化データ分配手段は、等値化対象となるデータの配置に 基づいて、データの収集・分配時のデータ転送に最適な 転送方式を組合わせて構成することにより、高速な等値 化処理を実現できる。

#### [0020]

【発明の実施の形態】図1は本実施形態のPCの構成を示す図である。本実施形態のPCでは、複数のCPUモジュール2、複数のI/Oモジュール3及び通信モジュール4がリング型の伝送トポロジーをもつシステムバス1によって接続されるネットワーク構成をもつ。このシステムバス1に接続されている各モジュールは、そのネットワーク上での通信局としてそれぞれを一意に識別する局番が設定されている。また各CPUモジュール2は、1対1のデュプレックス構成にして冗長性を持たせてあり、図1ではCPU1~CPU4が辞酬側。CPU

5~CPU8が稼動側それぞれに1対1対応する待機側となっている。

【0021】モジュール間の通信は、データ送信を行うモジュールが、送信先を局番で指定したフレームをシステムバス1上に送信する。このフレームは、システムバス1上を一定方向に巡回し、システムバス1上の各局は、上流局から送信されてきたフレームが自局宛のものでなければそのまま下流局に送り、自局宛のものあればそれを取込む。これによってシステムバス1上をフレームが一定方向に巡回する。

【0022】本実施形態では、稼動側CPUから待機側CPUへ送信される等値化データは、マルチキャスト方式によるデータ通信によって転送される。以下にマルチキャスト方式によるデータ転送について説明する。

【0023】マルチキャスト方式は、システムバス1上にマルチキャスト通信用のフリートークンを巡回させ、データ伝送を要求する局(出力装置に出力するための送信データが用意されており、また当該送信帯域の送信許可設定がされている局)はそのフリートークンを確保して代わりにマルチキャストフレームの送信を行う。マルチキャストフレームはシステムバス1上を巡回し、このマルチキャストフレームを受信したネットワーク上の局は、それを下流へ中継して巡回させると共にフレーム内の出力データの設定内容に基づいてデータの取込みを行う。

【0025】マルチキャスト方式は、稼動側CPUモジュールから待機側CPUモジュールに等値化データを送信する他に、CPUモジュール2から出力機器が接続されている I / Oモジュール3 に対してデータの出力を行う時用いられるデータ転送方式である。

【0026】マルチキャスト方式による通信では、まず、システムバス1上に1つだけ存在するネットワーク管理を行うリングマスター局が、データ転送の権限を制御するフリートークンを生成し、システムバス1上にリリースする。このフリートークンのリリースによって、マルチキャスト通信は開始される。

【0027】リリースされたフリートークンは、各局が順次下流局へ中継してゆき、システムバス1上を巡回する。そしてデータの出力を行いたいCPUモジュール2は、このフリートークンを受信すると、これをシステムバス1から確保し、マスター局となる。

る局番が設定されている。また各CPUモジュール2 【0028】マスター局は、用意してある送信データは、1対1のデュプレックス構成にして冗長性を持たせ を、SD部にこのフレームがマルチキャスト通信のフレてあり、図1ではCPU1~CPU4が稼動側、CPU 50 一ムであることを示すデータを設定したマルチキャスト

フレームとしてシステムバス1上に流す。図2では、マスター局は、保持したフリートークンの代わりにDo1局に対する出力データ(M->Do1)とDo2局に対する出力データ(M->Do2)の2つの局に対する出力データがマルチキャストフレームとして、下流局Do2へ送信される。

【0029】このマルチキャストフレームを受取った局は、そのフレーム内の出力データに設定されている出力データの格納先の局番を参照し、この出力データが自局に対するものであれば、それを取込むと共にそのフレー 10ムをそのまま下流局へ送信する。図2では、マルチキャストフレームを受信したDo2局及びDo1局はそれぞれ自局にあててマスタ局が出力した出力データ(M->Do2、M->Do1)を取込むと共に、その受信フレームをそのまま隣の下流局であるリングマスター局及びマスター局へ送信する。

【0030】フレームが1巡すると、そのフレームを最初に送信したマスタ局は、これをシステムバス1から除去し、代わりにフリートークンを生成して1上にリリースする。

【0031】そしてフリートークンがシステムバス1を1巡して戻ってくると、リングマスター局はデータ伝送要求の有無をチェックし、要求があれば当該送信データの送信を行う。その後、自局が送信したデータフレームがシステムバス1を1巡して自局に戻ってきたことでリングマスター局はフリートークンをシステムバス1上から除去し、これによってマルチキャスト通信は終了する。

【0032】尚、マルチキャスト通信に限らず、システムバス1上では、リングマスター局のデータフレームは 30 常に最後に送信される。次に本実施形態におけるシステムでの等値化処理について説明する。

【0033】図3は、本システムにおける稼動側CPU11と待機側CPU12との間の等値化データの流れを示す図である。同図は、稼動側CPU11とその稼動側CPU11に対応する待機側CPU12の等値化データの送受信に関連する部分のみを抽出して示している。本実施形態では、等値化データはシステムバス1を介してマルチキャスト方式によって稼動側CPU11から待機側CPU12へ送信される。

【0034】稼動側CPU11では、収集処理として、アプリケーションデータ領域14から等値化が必要なデータのみスキャンしてフレーム送受信作業領域15に収集する。そしてこの収集した等値化データをマルチキャスト方式で待機側CPU12に送信する(以下の説明では等値化データを送信するフレームを等値化フレームという)。この際、等値化データ数が多く、1タクト周期で送信出来ない重の場合、後述する様に複数のフレームに分けて送信することになる。フレーム送受信領域15は、複数のフレーム領域に分かれており、各フレーム領

域が1つの送信フレームで送るデータを格納する場所となっている。稼動側CPU11及び待機側CPU12では、イニシャライズ時にシステムを構成するモジュール数等から1タクト周期で送信できる等値化フレームサイズを計算することにより、等値化データをいくつの等値化フレームで送信するかを判断し、その分の領域及びダミー領域(ダミー領域については後述する)をフレーム送受信作業領域15に用意する。

【0035】フレーム送受信領域15内の等値化データは、バスコントローラ16内の送信バッファ17を介してマルチキャストフレームに格納されて、システムバス1上に送信される。送信ポインタ18は、次にフレーム送信するデータが格納されているフレーム領域を指すポインタでデータを送信する度に、次のフレーム領域に動く。

【0036】待機側CPU12では、このマルチキャストフレームを受信し、バスコントローラ16内の受信バッファ19を介してフレーム送受信作業領域15に各受信フレーム毎に格納する。尚この時フレーム送受信領域2015の格納位置を受信ポインタ20によってポイントし、受信ポインタ20はフレームを受信する度に次のフレーム領域に動く。フレーム送受信作業領域15に格納された等値化データは、アプリケーションデータ領域14へ古い等値化データを上書きする形で分配され、格納されてゆく。そして待機側CPU12が稼動側に切り替わった際には、アプリケーションプログラムはこのアプリケーションデータ領域14内のデータを用いて稼動側CPU11上のアプリケーションプログラムの処理を引き継ぐ。

【0037】本システムでは、等値化処理を行うタスク (以下等値化タスクという)を、等値化データの収集処 理(等値化準備)と等値化データを送信する処理とに分 ける。このうち収集処理は、デフォルトタスクのタスク 実行処理終了のタイミングで行う。また等値化データ送 信処理は、タスク実行とは独立にし、定周期タスクと並 列に行わせるようにする。また、等値化データの量が多 い場合、等値化データを複数のフレームに分けて送信 し、これら各等値化フレームの送信処理はそれぞれ独立 させてある。この様に本実施形態では、等値化処理を複 数の細かい処理に分けてそれぞれを独立させてある。従 って等値化処理が開始された後に定周期タスクを実行さ せなければならなくなっても、等値化処理が完了するの を待たずに、細かく分けた処理と処理の間に定周期タス クを割込ませ、定周期タスクが完了したら等値化処理に 戻ることが出来る。この構成により、等値化データの量 が多く等値化処理に多くの時間がかかる場合において も、定周期タスクの定周期性を崩さないで、等値化処理 を行うことが出来る。

に分けて送信することになる。フレーム送受信領域15 【0038】図4は、定周期タスク、デフォルトタスクは、複数のフレーム領域に分かれており、各フレーム領 50 及び等値化タスクによる等値化データの収集・送信のタ

イミングを示すタイミング図である。同図中の縦線はタ クト割込みを示し、このタクト割込みの間が1つのタク ト周期となる。また各タスク処理は、IOデータの入力 処理(網かけ部分)、IOデータの出力処理(斜線部 分)、計算処理等入出力処理以外のタスク実行処理(無 地部分)に分けて示してある。

【0039】図4での「デフォルトタスクエンド有 り」、「デフォルトタスク起動禁止」、「デフォルトタ スク〇禁止」及び「収集要求」は、稼動側CPU11上 に設けられた状態フラグの変化を示してる。また「送信 10 ポインタ」は、送信ポインタがどのフレーム領域を指し ているかを示している。「等値化タスクのステート」 は、等値化処理を行うタスクの処理状態を示している。 【0040】「デフォルトタスクエンド有り」フラグ は、等値化対象のデータの収集タイミングを作るフラグ で、デフォルトタスクのタスク実行処理が終了すると〇 N(1)になり、等値化対象のデータの収集処理が終了 するとOFF(0)となる。

【0041】「デフォルトタスク起動禁止」フラグは、 ルトタスクの実行処理が終了して「デフォルトタスクエ ンド有り」フラグがONとなった状態で新たなタクト周 期に入るとONとなり、全ての等値化データの送信が完 了して等値化処理が完了するとOFFとなる。このフラ グがONの間、定周期タスクの起動は許可されるが、デ フォルトタスクの起動は禁止される。

【0042】「デフォルトタスクO禁止」フラグは、デ フォルトタスクによる出力処理の開始を等値化処理が完 了するまで待たせるフラグで、デフォルトタスクのタス ク実行処理が終了するとONとなり、最後の等値化フレ ームの送信を開始するとOFFとなる。このフラグがO FFになってからデフォルトタスクはIOデータ出力処 理を開始する。

【0043】「収集要求」は、等値化処理を行うタスク が収集処理を可能な期間を示すフラグで、「デフォルト タスク起動禁止」フラグと共にONとなり、収集処理が 完了するとOFFとなる。

【0044】図4の41部分に示す様に、デフォルトタ スクのタスク実行処理の終了に対応して「デフォルトタ スクエンド有り」フラグがONになる。これにより等値 40 化データの収集、送信処理(システムデータ処理)を開 始できるようになる。「デフォルトタスクエンド有り」 フラグがONになると次のタクト割込みで「収集要求フ ラグ」がONとなる。定周期タスクのIO入力処理が完 了した時、との「収集要求フラグ」の状態を見て、ON となっていれば等値化データの収集処理を開始する。そ して収集処理が完了すると、収集した等値化データの待 機側CPUへの送信処理を行う。

【0045】この等値化データの収集、送信処理を行っ

して、デフォルトタスクの出力処理がこの収集、送信処 理に割り込むことを禁止する。しかしこの間、定周期タ スクに対しては処理に割込んで起動することを許可す る。これにより定周期タスクは定周期性を崩さずに処理 を実行することが出来る。

【0046】また本システムでは、稼動側CPUと待機 側CPUとの間で等値化を行うデータの数が多く、待機 側CPUに送信する量が多い場合、システムで取り決め た1タクト周期内で送信できる大きさに等値化データを 分割し、これらを固定サイズの複数の等値化フレームに 分けて格納し、タクト周期に同期して1フレームづつ送 信する。図4の42部分ではN個のフレームに分割して 等値化データを送信した場合を示している。

【0047】等値化データを待機側CPUへ送信する等 値化フレームの構成例を図5に示す。図5の等値化フレ ームは、マルチキャスト方式で送信されるフレームで、 CPU間マルチキャストフレームヘッダ部とデータ部に 分けられる。このうちCPU間マルチキャストフレーム ヘッダ部には、フレームの種類を知らせるFC、フレー 等値化処理が行われている期間を示すフラグで、デフォ 20 ムの大きさを示すTS、自CPUモジュールのシステム バス1上のアドレスSA、送信先である待機側CPUモ ジュールのアドレスDA、等値化フレーム部分の大きさ を示すサイズが格納されている。また、データ部には等 値化データの他に、受信したフレーム内の等値化データ の整合性をチェックする為のシリアルNo. 及びフレーム No. が格納されている。このシリアルNo. とフレームN o. については後述する。

> 【0048】 この等値化フレームは固定長で、1タクト 周期内で送信できる最大のデータサイズからシステムが 30 求めた大きさになっている。図6は、1タクト周期内に 稼動側CPUから送信されるデータを示す図である。1 タクト周期内には等値化データの他に、I/Oモジュー ル3や通信モジュール4等のシステムを構成している他 のモジュールへの送信データであるシステム制御データ が送信される。このシステム制御データを送信するフレ ームには、I/Oモジュール3への出力データを含む制 御IO入出力フレーム、モジュールの各種ステータスを 含む状態フレーム及び通信モジュールへのメッセージを 含むメッセージフレームがある。

【0049】稼動側CPU及び待機側CPUでは、1タ クト周期内に送信できる最大データサイズとこのシステ ム制御データの大きさを考慮して、1フレームに格納す る等値化データの数を可変制御する。稼動側CPU及び 待機側CPUは、システムを構成するモジュールの種類 や数から、等値化フレームの大きさを決定するが、基本 的には、システム構成が大きくなればなるほど1フレー ムで送信できる等値化データサイズは小さくなり、シス テム構成が小さければ小さいほど大きくなる。

【0050】この等値化フレームに格納できる等値化デ ている間、「デフォルトタスクO禁止」フラグをONに 50 ータの大きさ(等値化データ数)は、システム制御デー

11

タ数と等値化データ数から式(1) の様に求まる。

1 タクト周期内で送信できる最大データサイズ=システム制御データサイズ+ 等値化データサイズ・・(1)

式(1) でシステム制御データサイズは、図6の制御IO 入出力フレーム、状態フレーム及びメッセージフレーム で送信される制御用のI/Oモジュール3に対する入出 力データ、通信モジュール4へのメッセージデータ及び\* \*各種ステータスの大きさを加えたものである。よって、 等値化データサイズは、式(2) に示すように1タクト周 期で転送できる最大のフレームでのデータサイズから、 システム制御データサイズを引いたものである。

12

等値化データサイズ=1タクト周期内で送信できる最大データサイズ-システム制御データサイズ・・(2)

本実施形態では等値化データを複数のフレームに分割して送信するため、これを受信する待機側CPUで受信フレームの整合性をチェック出来るように、等値化データを送信する等値化フレームには、フレームNo. 及びシリアルNo. を挿入してある。

【0051】図7は、等値化データを3つのフレームに分けて送信する場合を例とした、稼動側CPUでのフレーム送信時、及び待機側CPUがフレーム受信時のフレーム送受信作業領域15と送信ポインタ18及び受信ポ 20インタ20の状態を示す図である。

【0052】稼動側CPUでは、収集処理により収集された等値化データは、フレーム送受信作業領域15の3つのフレーム領域に分けて格納される。そして送信ポインタ18の指すフレーム領域のデータから順次等値化フレームに格納されて送信される。これらの等値化フレームにはフレームNo.及びシリアルNo.が格納されており、図7のシステムバス領域部分に記されているx/yが各フレーム内のフレームNo.、Ser.zがシリアルNo.を表している。

【0053】フレームNo.は、複数に分割された等値化データのうちの何番目かを示す番号で同図ではx/yで表されているもののうちのy部分が分割した数、x部分がそのうちの何番目のデータにあたるかを示しx部分がそのうちの何番目のデータにあたるかを示す。同図の場合3つのフレームに分割されているので、フレームNo.は、1/3~3/3の値を取る。このフレームNo.は待機側CPUで、等値化フレームが飛ばされずに到達しているかをチェックするのに用いる。

【0054】シリアルNo. は、そのフレームがどの等値 40 化処理に対する等値化データを含むフレームかを示すもので、稼動側CPUで等値化データの収集処理を行う毎に1、2、・・と番号がインクリメントされて付せられる。シリアルNo. は、収集したデータの同期を保証するために用いられ、待機側CPUは、同一のシリアルNo. が付せられているフレームは同じ処理処理によって集められた等値化データの一部と認識して処理する。

【0055】稼動側CPUでは、収集処理が完了するとフレーム送受信作業領域15内の送信ポインタ18が指すフレーム領域内の等値化データをマルチキャスト送信

により待機側CPUに送信する。この時、各等値化フレームには、同じシリアルNo.を格納し、また送信順に例えば1,2,・・とその順番が分るようにフレームNo.を格納する。

【0056】またアプリケーションデータ領域14から等値化データを収集している間等、全等値化データの送信完了後次の等値化データを送信するまでの間、稼動側 CPUは等値化データを含まないダミーフレームを待機側CPUに送信する。このダミーフレームには、シリアルNo.として予め決められた特別な番号が設定されてもり、フレームを受信した待機側CPUでは、受信フレームのシリアルNo.にこの番号が格納されているとこのフレームがダミーフレームであるとを認識する。そして待機側CPUは、ダミーフレームを受信することにより、稼動側CPUは1つの収集処理によって集められた等値化データを送信する全ての等値化フレームの送信を完了したと認識する。図7の場合、ダミーフレームにはシリアルNo.として0が格納されている。

30 【0057】待機側CPUは、稼動側CPUが複数のファイルに分割して送った等値化データを全て正常に受信した場合にのみ、アプリケーションデータ領域14に等値化データを分配する。この受信した等値化データの整合性のチェックは、フレームNo.及びシリアルNo.によって行われる。

【0058】待機側CPUは、ダミーフレームを受信すると全ての等値化データを受信したと判断して、全等値化フレームのフレームNo. とシリアルNo. から受信した等値化データの整合性を調べる。そして問題なければ、フレーム送受信作業領域15からアプリケーションデータ領域14に等値化データを分配する。

【0059】待機側CPUは、稼動側CPUが送り出す ことになっている等値化フレームのフレームNo. 及びシ リアルNo. と、実際に受信した等値化フレーム内のフレ ームNo. 及びシリアルNo. とを比較する。そして両者が 一致すれば、これをアプリケーションデータ領域14に 分配し、一致しなければ伝送異常等によりフレームが欠 落したなど正常にフレームが届かなかったので、受信デ ータを破棄する。

すフレーム領域内の等値化データをマルチキャスト送信 50 【0060】図7の71部分には両者が一致し、受信デ

(8)

ータを等値化データとしてアブリケーション領域14に分配する場合を、又同図72部分には両者が一致せず、送られてきた等値化データを破棄してアプリケーションデータ領域14への等値化データの分配は行わない場合を示す。同図71部分の場合、受信した等値化フレームのシリアルNo.が全て1で、フレームNo.が1/3,2/3,3/3の順だったので正常の受信として、フレーム送受信作業領域15からアブリケーションデータ領域14に受信した等値化プレームにシリアルNo.が1の10ものと2のものがあるので、これらの受信フレーム内の等値化データはアプリケーションデータ領域14へ分配せずに破棄している。

13

【0061】また稼動側CPUは、全フレームのデータ収集の同期を保証するため、等値化データを全て送信してから新たな等値化データの収集処理が完了するまで、ダミーフレームを送信する。収集処理が完了する前に等値化データを送信してしまうと不定なデータが送られてしまうので、稼動側CPUでは、最後の等値化フレームを送信してから次の収集処理が完了するまでの間、送信 20ポインタ18をダミー領域のアドレスであるダミーアドレスに固定しておき、ダミーフレームを送信する。

【0062】この時待機側CPUでは、アプリケーションデータ領域14への等値化データの分配処理を行っているが、フレーム送受信作業領域15内の等値化データがダミーフレームのデータで上書きされないように、この分配処理が終るまで、受信ポインタ20をフレーム送受信作業領域15内のダミーアドレスに固定しておく。これにより、受信したダミーフレームは、ダミーアドレスの指す等値化データが未格納な領域に格納され、等値化データが格納されているフレーム送受信作業領域15への上書きがされないようになっている。尚等値化データの分配処理が終了したら、受信フレームがまたダミーフレームであっても受信ポインタ20を通常の等値化フレームの受信位置に戻す。ただこの場合ダミーフレームを受信している間は、受信ポインタ20は移動させない。

【0063】図7の73部分に示すように、稼動側CPUは、アプリケーションデータ領域14からの等値化データの収集処理が完了するまでの間は、ダミーフレームを待機側CPUに送信する。ダミーフレームには予め決めておいた特別な番号である0がシリアルNo.として格納されているので、等値化フレームを受信した待機側CPUでは、シリアルNo.を調べることによってこのフレームがダミーフレームであることを認識する。

【0064】稼動側CPUは、ダミーフレームを送信することにより、待機側CPUに稼動側CPUが等値化データの送信を完了して次の等値化データの送信準備中であることを認識させる。また受信したフレーム内のデータはフレーム送受信作業領域15に上書きして格納する50

が、ダミーフレームを受信中は、受信ポインタ15を移動させないことにより、受信したダミーフレーム内のデータを同じ領域に上書きして格納する。

【0065】また稼動CPUは、複数の等値化フレーム に分けて等値化データを送信する際、途中の等値化フレ ーム送信に中送信異常が起きた場合、以降残っているフ レームの送信をやめる。そして直ちにアプリケーション データ領域14をスキャンをして等値化データの再収集 処理を行い、等値化処理を継続をする。この様に送信異 常が発生してしまった等値化データの送信処理を中止す ることにより、新たな等値化データの収集処理、及びそ の等値化データの送信処理に直ちに取り掛かれる。図7 の74部分では、最初の等値化フレーム(フレームNo. が1/3のフレーム)の送信中に送信異常が発生したの で、以降のフレーム(フレームNo. が2/3, 3の/3 フレーム)の送信を取り止め、次の等値化データの収集 処理を開始している。一尚との等値化データの再収集処理 が完了するまでの間、稼動側CPUはダミーフレームを 送信する。

20 【0066】またとの74の部分では、収集処理を開始するタイミングと定周期タスクによる処理が同時期に重なってしまっているが、との様な場合は、定周期タスクのIO入力処理を先に行い、これが完了した後等値化データの収集処理を行い、その後に定周期タスクの実行に移る。

【0067】次に稼動側CPUで行われる等値化データの収集処理及び待機側CPUで行われる等値化データの分配処理について説明する。稼動側CPUで行われるアプリケーションデータ領域14からフレーム送受信作業領域15への等値化データの収集処理及び待機側CPUで行われるフレーム送受信作業領域15からアプリケーションデータ領域14への等値化データの分配処理では、稼動側CPU、待機側CPU共に同じ内容の転送テーブルを用いて行われる。

【0068】図8に稼動側CPUで行われる等値化データの収集処理、図9に待機側CPUで行われる等値化データの分配処理を示す。図8及び図9は、等値化データを2つの等値化フレームに分けて送信する場合を例としており、フレーム送受信作業領域15には、送受信する2つのフレームのCPU間マルチキャストフレームへッダ部内のデータを格納しているへッダ部及びデータ部のデータを格納しているデータ部が示されている。

【0069】図8に示す稼動側CPUで行われる等値化データの収集処理の場合、アプリケーションデータ領域14からフレーム送受信作業領域15へ等値化データを収集するが、この処理は、アプリケーションデータ領域14のどの位置のデータをフレーム送受信作業領域15のどの位置に収集するかを記録している転送テーブル30を参照して行われる。

0 【0070】この転送テーブル30は、稼動側CPU及

び待機側CPUにおいて、CPUのイニシャライズ時に、CPUモジュール上で稼動されるユーザが作成したアプリケーションプログラムから等値化対象のデータを認識して作成される。稼動側CPUとそれに対応する待機側CPUでは、同じアプリケーションプログラムがインストールされているため、稼動側CPUと待機側CPUでは等値化対象データも同じ、更にその転送方式も同じになる。よって稼動側CPU及び待機側CPUでは、転送テーブル30として全く同じものが作成されることになる。稼動側CPU及び待機側CPUでは、稼動/待10機の切替えに備え、等値化データの収集用の転送テーブルとアプリケーションデータ領域14への分配用転送テーブルの両方を実装するが、本実施形態では同じ転送テーブルを用いて収集処理と分配処理を行えるので、メモリ資源を有効に用いることが出来る。

【0071】転送テーブル30にはいくつのフレームに 分けて等値化データを送信するかを示すブロック数N、 後述するアプリケーションデータ領域14とフレーム送 受信作業領域15の間のデータの転送方式、及びブロッ ク数N分のフレーム送受信作業領域15側のアドレスを 20 示すフレーム側アドレス、データの個数及びアプリケー ションデータ領域側アドレスが記録されており、その構 成は転送方式によって異なる。また複数の転送方式を組 合わせて行う場合(例えば図8に於て、D1~D5をブ ロック転送、D100~D104を構造体転送で行う場 合等)には、転送テーブル30には、各転送方式毎にこ れらの情報が記録されている。稼動側CPUで行われる 等値化データの収集処理では、この転送テーブル30の アプリケーションデータ領域側アドレスを転送元アドレ ス、フレーム側アドレスが転送先アドレスとして等値化 30 データを収集する。

【0072】稼動側CPUで収集された等値化データは、等値化フレームに格納されて待機側CPUに送信され、待機側CPUでは、受信した等値化フレームをフレーム送受信作業領域15に格納し、この中のデータ部内の等値化データを図9に示すように転送テーブル30を用いてアプリケーションデータ領域14に分配する。

【0073】との分配処理では稼動側CPUでとの等値化データの収集処理に用いられた転送テーブル30と同じ転送テーブル30を、図8の収集処理の時とは逆に、フレーム側アドレスを送信元、アプリケーションデータ領域側アドレスを送信先としてデータの転送を行う。このように同じ転送テーブル30を、稼動側CPUと待機側CPUとで転送元アドレスと転送先アドレスを逆にして用いることによりメモリ資源の節約をすることが出来る。

【0074】本実施形態では、アプリケーションデータ 領域14とフレーム送受信作業領域15との間で行われる等値化データの転送方式として、ブロック転送、ワート転送及び構造対転送の3つの転送方式を持つ、また名 転送方式によって用いられる転送テーブル30は、転送方式毎にアプリケーションデータ領域側アドレス部分の構成が異なっている。 稼動側CPU及び待機側CPUでは、イニシャライズ時に等値化対象とするデータのアプリケーションデータ領域14の配置位置からデータの収集・分配時のデータ転送に最適な転送方式を選択し、或いは必要に応じて複数の転送方式を組合わせて対応する転送テーブル30を作成する。

【0075】図10に、ブロック転送方式によって用い

られる転送テーブルの構成例を示す。 尚同図及び図11

及び図12は、ブロック数N=1の時のものでブロック 数Nが2以上の時は、転送テーブル30はフレーム側ア ドレス、個数及びアプリケーションデータ領域側アドレ スに対応する部分をブロック数分持つことになる。 【0076】ブロック転送方式は、アプリケーションデ ータ領域 14の一定の領域の全てのデータを等値化する 時に行う転送方式で、ブロック単位でデータ転送を行 う。図10の転送テーブルには、アプリケーションデー タ領域側アドレスとして個数部分に記録されている組分 のワード数とアドレスが組となって記録されている。 【0077】ブロック転送の際は、転送テーブルに格納 されているアドレスからワード数分のデータをブロック 単位で転送する。例えば図8の等値化データの収集処理 が、ブロック転送によるものである時、図10のアドレ ス1にはアプリケーションデータ領域14のD1の先頭 アドレス、ワード数1にはD1の総ワード数が格納さ れ、アドレス2にはアプリケーションデータ領域14の D2の先頭アドレス、ワード数2にはD2の総ワード数 が格納されている。等値化データの収集処理時には、D 1としてアドレス1からデータをワード数1分読み出 し、フレーム送受信作業領域15のフレーム側アドレス に格納されているアドレス部分に格納する。次にD2と してアドレス2からデータをワード数2分読み出し、フ レーム送受信作業領域15のD1を格納した続きに格納 する。以降、転送テーブル30のアプリケーションデー

【0078】また等値化データの分配処理では、D1としてフレーム送受信作業領域15のフレーム側アドレスに記憶されている位置からワード数1分データを読み出し、これをアプリケーションデータ領域14のアドレス1部分に格納し、次にD2としてフレーム送受信作業領域15のD1を読み出した続きからワード数2分のデータを読み出し、これをアプリケーションデータ領域14のアドレス2部分に格納する。以降全データに対して同様の処理を行うことで、転送テーブル30を用いた等値化データのアプリケーションデータ領域14への分配が行える。

タ領域側アドレス部分に記録されている全アドレス及び

ワード数に対して同様の処理を行う。

る等値化データの転送方式として、ブロック転送、ワー 【0079】次にワード転送方式について説明する。ワ ド転送及び構造対転送の3つの転送方式を持つ。また各 50 ード転送方式は、1ワード単位で独立に制御して等値化 する時に使用する転送方式で、転送テーブル30で転送 するデータを1ワード単位で指定する。

【0080】図11に、ワード転送方式によって用いられる転送テーブルの構成例を示す。図11の転送テーブルには、アプリケーションデータ領域側アドレス部分に個数部分に記録されている数のアドレスが記録されている。

【0081】等値化データの収集処理をワード転送で行う際は、アプリケーションデータ領域14のアプリケーションデータ領域170アプリケーションデータ領域側アドレス部分に格納されている各ア 10ドレスから1ワードづつ読み出し、フレーム送受信作業領域15のフレーム側アドレスに格納されている部分に順次転送する。また等値化データのアプリケーションデータ領域14への分配処理時には、フレーム送受信作業領域15のフレーム側アドレス部分に格納されたアドレスから順次1ワードづつ読み出し、アプリケーションデータ領域14のアプリケーションデータ領域側アドレス部分に格納されているアドレスの位置に転送して行く。

【0082】次に構造体転送について説明する。構造体 転送は、変則的な位置のデータを指定して転送する場合 20 に用いる転送方式でで3種類のモードが有る。

【0083】図12は、構造体転送に用いられる転送テーブルの構成例である。図12の転送テーブルには、アプリケーションデータ領域側アドレス部分に個数部分にアドレスが1つ記録されている。また転送方式部分には、どのモードによる構造体転送かを示すモード番号0~2が記録されている。

【0084】図13、図14及び図15はモード1,2 および3での構造体の例を示す図である。各図中の

(R)の印のワードの所を等値化対象としてアプリケー 30 ションデータ領域14から読み出し、(M)部分を等値 対象としないことを表している。

【0085】モード番号0のモード1の場合は、図13に示すように2ワード構造のうち2ワード共等値化対象とする。このモード1の構造体転送において、例えば個数に3が設定されていたならば、収集処理においてアプリケーションデータ領域側アドレスのアドレス部分から連なる2×3=6ワードのデータを読み出して収集する。又分配処理の時は、上記アドレスに記録されているアドレス値の部分にフレーム送受信作業領域15からのフレーム側アドレス部分から読み出した6ワードのデータを格納する。

【0086】モード番号1のモード2の場合は、図14に示す様に4ワード構造のうち3・4ワード目を等値化対象としてデータ転送を行う。このモード2の構造体転送において、例えば個数に3が設定されていたならば、収集処理においてアプリケーションデータ領域14の指定アドレス部分から3・4ワード目、7・8ワード目及び11・12ワード目のデータを等値化データとして読み出して収集する。また分配処理時には、フレーム送受50

信作業領域15の転送テーブルによって指定された位置 から読み出した6ワードのデータをアプリケーションデータ領域14の指定アドレスから3・4ワード目、7・

18

ーダ領域14の指定アトレスから3・4ワート日、 /・ 8ワード目及び11・12ワード目の位置に格納して行 く。

【0087】モード番号2のモード3場合は、図15に示すように8ワード構造のうち、1・2・5・6ワード目を等値化する。例えば、個数に2が設定されていたならば、収集処理においてアプリケーションデータ領域14の指定アドレス部分から1・2・5・6ワード目及び7・8・11・12ワード目のデータを等値化データとして読み出して収集し、分配処理時には、フレーム送受信作業領域15の転送テーブルによって指定された位置から読み出した6ワードのデータをアプリケーションデータ領域14の指定アドレスから1・2・5・6ワード目及び7・8・11・12ワード目の位置に格納して行く。

【0088】この様に、本実施形態では、等値化対象のデータのアプリケーションデータ領域14での配置によって最適な転送方式を選択したり、或いは複数の転送方式を組合わせることが出来るので、スピーディに収集・分配処理を行うことが可能となり、高速に制御データの等値化処理を行うことが出来る。

[0089]

【発明の効果】以上説明のように、本発明によれば、稼動側CPUで行われている定周期タスクの定周期性を崩すことなく、等値化処理を実行することが出来る。

【0090】また、複数の等値化フレームに分けて等値 化データを送信することにより、等値化データの量が多 くてもタクト周期の周期性を壊すことが無い。更に稼動 側CPUでは、収集処理中には、ダミーフレームを送信 することにより収集が完了する前のデータが送信される ことが無い。

【0091】また複数の等値化フレームの送信中に送信 異常が発生してしまった時、以降の等値化データの送信 処理を中止することにより、新たな等値化データの収集 処理、及びその等値化データの送信処理に直ちに取り掛 かれる。

る。又分配処理の時は、上記アドレスに記録されている 【0092】更に待機側CPUでは、受信した等値化デアドレス値の部分にフレーム送受信作業領域15からの 40 ータの整合性のチェックを行うことが出来る。また、等フレーム側アドレス部分から読み出した6ワードのデー 値化データの分配処理中に受信したフレームのデータでタを格納する。 分配処理中のデータが上書きされることが無い。

【0093】更に収集処理と分配処理で転送テーブルを 共用することにより、メモリ資源の有効化を図れる。ま た等値化対象となるデータの配置に基づいて、データの 収集・分配時のデータ転送に最適な転送方式を選択し、 必要に応じて組合わせることにより、高速な等値化処理 を実現できる。

【図面の簡単な説明】

【図1】本実施形態のPCの構成を示す図である。

【図2】マルチキャスト方式による通信の説明図であ る。

19

【図3】稼動側CPUと待機側CPUとの間の等値化デ ータの流れを示す図である。

【図4】定周期タスク、デフォルトタスク及び等値化タ スクによる等値化データの収集・送信のタイミングを示 すタイミング図である。

【図5】等値化フレームの構成例を示す図である。

【図6】1タクト周期内に稼動側CPUから送信される データを示す図である。

【図7】稼動側CPUでのフレーム送信時及び待機側C PUがフレーム受信時のフレーム送受信作業領域と送信 /受信ポインタの状態を示す図である。

【図8】稼動側CPUで行われる等値化データの収集処 理を示す図である。

【図9】待機側CPUで行われる等値化データの分配処 理を示す図である。

【図10】ブロック転送方式によって用いられる転送テ ーブルの構成例を示す図である。

【図11】ワード転送方式によって用いられる転送テー 20 19 受信バッファ ブルの構成例を示す図である。

【図12】構造体転送方式によって用いられる転送テー ブルの構成例を示す図である。

\*【図13】モード1の構造体例を示す図である。

【図14】モード2の構造体例を示す図である。

【図15】モード3の構造体例を示す図である。

【図16】一般的なマルチCPU構成のPCの例を示す

【図17】等値化処理のタイミングを示す図である。 【符号の説明】

1、101 システムバス

2、102 CPUモジュール

10 3、103 1/0モジュール

4 通信モジュール

11 稼動側CPU

12 待機側CPU

13 実行プロセッサ

14 アプリケーションデータ領域

15 フレーム送受信作業領域

16 バスコントローラ

17 送信バッファ

18 送信ポインタ

20 受信ポインタ

30 転送テーブル

【図3】

## 稼動側CPUと待機側CPUとの間の等値化データの流れを示す図



【図1】

本実施形態のPCの構成を示す図



【図2】

マルチキャスト方式による通信の説明図



【図5】

#### 等値化フレームの構成例を示す図



【図6】

## 1タクト周期内に稼動側CPUから送信されるデータを示す図



【図12】

## 構造体転送方式によって用いられる転送テーブルの構成例を示す図



【図4】



【図7】



【図8】

# 稼動側CPUで行われる等値化データの収集処理を示す図



【図11】

# ワード転送方式によって用いられる転送テーブルの構成例を示す図



【図9】 待機側CPUで行われる等値化データの分配処理を示す図



【図13】

モード1の構造体例を示す図



【図16】

一般的なマルチCPU構成のPCの例を示す図



【図10】

# ブロック転送方式によって用いられる転送テーブルの構成例を示す図



【図14】

【図15】

## モード2の構造体例を示す図

## モード3の構造体例を示す図

等値化不要(M) 等値化不要(M) 等値化必要(R) 等値化必要(R)

| 等值化必要(R) |
|----------|
| 等值化必要(R) |
| 等值化不要(M) |
| 等值化不要(M) |
| 等館化必要(R) |
| 等値化必要(R) |
| 等條化不要(M) |
| 等值化不要(M) |
|          |

【図17】

# 等値化処理のタイミングを示す図



フロントページの続き

(51)Int.Cl.'

識別記号

FΙ

テーマコード(参考)

G 0 6 F 13/42

350

G 0 5 B 19/05

S

Fターム(参考) 58034 B802 DD06

58077 AA17 AA18 BA03 BA09 FF01

GG02 GG16

5B083 AA05 CC04 CE01 DD08 GG09

5H209 EE11 GG04 GG11 HH37 HH40

SS01 SS04 SS08

5H220 BB10 CC09 CX03 EE07 EE10

HH04 JJ12 JJ16 JJ29 JJ38

KK01 KK03 MM08

# This Page is Inserted by IFW Indexing and Scanning Operations and is not part of the Official Record

# **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

| ☐ BLACK BORDERS                                         |
|---------------------------------------------------------|
| $\square$ image cut off at top, bottom or sides         |
| FADED TEXT OR DRAWING                                   |
| ☐ BLURRED OR ILLEGIBLE TEXT OR DRAWING                  |
| ☐ SKEWED/SLANTED IMAGES                                 |
| ☐ COLOR OR BLACK AND WHITE PHOTOGRAPHS                  |
| ☐ GRAY SCALE DOCUMENTS                                  |
| ☐ LINES OR MARKS ON ORIGINAL DOCUMENT                   |
| ☐ REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY |
| ☐ OTHER:                                                |

# IMAGES ARE BEST AVAILABLE COPY.

As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.